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DETAILED ACTION 

Response to Amendment 

1 . Applicant's request for reconsideration of the finality of the rejection of the last 
Office action is persuasive and, therefore, the finality of that action is withdrawn. 



Claim Rejections - 35 USC § 103 

2. The following is a quotation of 35 U.S.C. 1 03(a) which forms the basis for all 
obviousness rejections set forth in this Office action: 

(a) A patent may not be obtained though the invention is not identically disclosed or described as set 
forth in section 102 of this title, if the differences between the subject matter sought to be patented and 
the prior art are such that the subject matter as a whole would have been obvious at the time the 
invention was made to a person having ordinary skill in the art to which said subject matter pertains. 
Patentability shall not be negatived by the manner in which the invention was made. 

3. Claims 1, 3, 5— 14, 16 and 18 - 22 are rejected under 35 U.S.C. 103(a) as being 
unpatentable over Hariguchi et al. (US 6,665,297) in view of Douceur (US 6,067,547). 

(1) with regard to claims 1 and 14: 

Hariguchi et al. discloses a system and method, comprising: a plurality of hash 
tables (82-8 -- 82-32 on Fig. 2A) each storing prefixes for address lookups; and a 
content addressable memory (80 on Fig. 2A) storing at least some prefixes for which a 
collision occurs within at least one of the hash tables (column 6, lines 31 - 39); and a 
hashing lookup search mechanism that comprises a routing table (40 on Fig. 2A) 
implemented with selective hashing for a plurality of prefixes with different lengths 
(column 5, lines 20 - 24); and a plurality of memory blocks (memory blocks in each 
hash bucket 160), wherein each hash table is allocated a group of the memory blocks. 
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(column 6, line 66 - column 7, line 2; column 8, line 56 - column 9, lines 7; each hash 
circuit comprises a hash bucket which comprises memory blocks for storing route 
entries, see 160 on Fig. 4; memory blocks are inherent because each hash bucket 
stores route entries such as network addresses); and a configuration register (mask 
circuit, 154 on Fig. 4) associated with reach memory block, each configuration register 
identifying the prefix length to which the respective memory block is allocated (e.g. see 
column 6, lines 54 - 61). 

Hariguchi et al. does not disclose each hash table is allocated a group of the 
memory blocks based on a size of the respective hash table. 

Douceur teaches a hash table is allocated a group of memory blocks based on a 
size of the respective hash table (column 19, line 23-26; line 62 - 67). 

It would have been obvious to one of ordinary skill in the art at the time of the 
invention to modify the system of Hariguchi to allocate a group of the memory blocks to 
each hash table based on a size of the respective hash table as suggest by Douceur in 
order to make use of memory resource more efficient. 

(2) with regard to claims 3 and 16: 

Hariguchi et al. does not disclose each hash table is allocated no more than a 
predefined number of memory blocks. 

Douceur teaches a hash table is allocated no more than a predefined number of 
memory blocks (column 9, line 62 - 67; the size of the primary memory 22 is inherently 
predefined and a hash table can not be allocated more than the size of the primary 
memory). 
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It would have been obvious to one of ordinary skill in the art at the time of the 
invention to modify the system of Hariguchi so that each hash table is allocated no more 
than a predefined amount of memory as shown in Douceur in order to make use of 
memory resource more efficient. 

(3) with regard to claims 5 and 18: 

Hariguchi et al. further discloses each hash table containing different length 
prefixes (column 5, lines 20 - 31 , hash table 70 comprises a plurality of hash circuit 82; 
each hash circuit 82 determines a match based on a predetermined portion of the 
address using its associated prefix length). 

(4) with regard to claims 6 and 19: 

Hariguchi et al. further discloses a priority encoder (172 on Fig. 5) selecting a 
longest prefix when a plurality of matches occur between different length portions of a 
prefix and prefixes in each of two or more of the plurality of hash tables (column 8, lines 
4-8) 

(5) with regard to claims 7 and 20: 

Hariguchi et al. further discloses that the plurality of hash tables contain only a 
subset of different length prefixes possible under an addressing scheme, and wherein a 
remainder of the different length prefixes are stored in the content addressable memory 
(column 6, lines 30-39). 

(6) with regard to claim 8: 

Hariguchi et al. discloses a network router (26 on Fig. 2A) including the address 
lookup structure according to claim 1 , the network router further comprising: a network 
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search engine (70 on Fig. 2A) containing the at least one hash table and coupled to the 
content addressable memory, the network search engine performing address lookups 
using the at least one hash table; and an external memory (98 on Fig. 2A) coupled to 
the network search engine and containing per route information indexed by a next hop 
index generated by the network search engine. 

(7) with regard to claim 9: 

Hariguchi et al. discloses a network (20 on Fig. 1) including a plurality of 
interconnected network routers (26, 28, 30 - 38 on Fig. 1 ) according to claim 8. 

(8) with regard to claim 10: 

Hariguchi et al. discloses that a plurality of hash tables, each hash table 
containing different length prefixes (column 5, lines 20 - 31); each hash table containing 
different length than prefixes within other hash tables with in the plurality (column 5, 
lines 20 - 31); and the plurality of hash tables collectively containing only a subset of 
different prefix lengths less than or equal to an address lengths and a remainder of the 
different address lengths are handled by an additional address lookup facility (column 6, 
lines 30 - 39); and a hashing search mechanism that comprises a routing table (40 on 
Fig. 2A) implemented with selective hashing for a plurality of prefixes with different 
lengths (column 5, lines 20 - 24); and a plurality of memory blocks, wherein each hash 
table is allocated a group of the memory blocks, (column 6, line 66 - column 7, line 2; 
column 8, line 56 - column 9, lines 7; each hash circuit comprises a hash bucket which 
comprises memory blocks for storing route entries, see 160 on Fig. 4; memory blocks 
are inherent because each hash bucket stores route entries such as network 
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addresses); and a configuration register (mask circuit, 154 on Fig. 4) associated with 
reach memory block, each configuration register identifying the prefix length to which 
the respective memory block is allocated (e.g. see column 6, lines 54 - 61). 

Hariguchi et al. does not disclose each hash table is allocated a group of the 
memory blocks based on a size of the respective hash table. 

Douceur teaches a hash table is allocated a group of memory blocks based on a 
size of the respective hash table (column 1 9, line 23 - 26; line 62 - 67). 

It would have been obvious to one of ordinary skill in the art at the time of the 
invention to modify the system of Hariguchi to allocate a group of the memory blocks to 
each hash table based on a size of the respective hash table as suggest by Douceur in 
order to make use of memory resource more efficient. 

(9) with regard to claim 1 1 : 

Hariguchi et al. further discloses the additional address lookup facility comprises 
a content addressable memory (80 on Fig. 2A; column 6, lines 30 - 39). 

(10) with regard to claim 12: 

Hariguchi et al. further discloses each of the plurality of hash tables in contained 
in one or more memory blocks allocated based on hashing of each prefix contained in 
the respective hash table using at least a first hash function (inherent be cause hash 
tables inherently use hash functions), wherein a number of memory blocks allocated to 
the respective hash table does not exceed a predefined number (inherent because the 
size of the memory use in an apparatus is always predefined and limited), and wherein 
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a remainder of prefixes of a length corresponding to prefixes within the respective hash 
table are handled by the additional address lookup facility (column 6, lines 30 - 39). 

(1 1 ) with regard to claim 1 3: 

Hariguchi et al. further discloses a priority encoder (172 on Fig. 5) selecting a 
longest prefix match from matches identified within the plurality of hash tables (column 
8, lines 4 -8). 

(12) with regard to claim 21 : 

Hariguchi et al. further discloses the configuration register identifies a prefix 
length between sixteen (16) and thirty-two (32) bits (column 6, line 56 - 61). 

(13) with regard to claim 22: 

Hariguchi et al. further discloses a configuration register (mask circuit, 154 on 
Fig. 4) identifies the hash function to which the respective memory block is allocated 
(e.g. see column 6, lines 54 - 61 ). 

4. Claims 2 and 15 are rejected under 35 U.S.C. 103(a) as being unpatentable over 
Hariguchi et al. (US 6,665,297) in view of Douceur (US 6,067,547) and further in view of 
McMahon et al. (US 5,784,699). 

(1) with regard to claims 2 and 15: 

Hariguchi et al. in view of Douceur discloses each hash table holds prefixes for 
which no collision occurs within the hash table (column 6, lines 31 - 39; column 9, lines 
12-15). 
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Hariguchi et al. does not disclose each hash table is allocated a smallest number 
of memory blocks sufficient to hold entries within the hash table. 

McMahon et al. teaches allocating a smallest number of memory blocks sufficient 
for use (column 3, line 54 - 58). 

It would have been obvious to one of ordinary skill in the art at the time of the 
invention to modify the system of Hariguchi to allocate a smallest number of memory 
blocks sufficient to each hash table as suggest by McMahon et al. in order to make use 
of memory more efficient. 

5. Claims 4 and 17 are rejected under 35 U.S.C. 103(a) as being unpatentable over 
Hariguchi et al. (US 6,665,297) in view of Delaney et al. (US 2001/0027479) and further 
in view of Tal et al. (US 6,625,61 2). 

(1) with regard to claims 4 and 17: 

Hariguchi et al. further discloses the at least one hash table (70 on Fig. 2A) 
contains prefixes hashed by one hash functions. Haiguchi et al. does not disclose a 
second of the two hash functions employed when a collision occurs with a first of the 
two hash functions. 

Tal et al. teaches using two hash functions and a second of the two hash 
functions employed when a collision occurs with a first of the two hash functions 
(column 1, lines 54-59). 

It would have been desirable to use a second hash function when a collision 
occurs with a first hash function because it would provide an efficient way to resolve 
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hash collision. Therefore, it would have been obvious to one of ordinary skill in the art 
at the time of the invention to include the method as taught by Tal et al. in the system of 
Hariguchi et al. 

Response to Arguments 

6. Applicant's arguments with respect to claims 1 - 22 have been considered but are 
moot in view of the new ground(s) of rejection. 

Conclusion 

Any inquiry concerning this communication or earlier communications from the 
examiner should be directed to BO HUI A. ZHU whose telephone number is (571)-270- 
1086. The examiner can normally be reached on Mon-Thu 10am-6pm. 

If attempts to reach the examiner by telephone are unsuccessful, the examiner's 
supervisor, Jay Patel can be reached on (571)-272-2988. The fax phone number for 
the organization where this application or proceeding is assigned is 571-273-8300. 
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Information regarding the status of an application may be obtained from the 
Patent Application Information Retrieval (PAIR) system. Status information for 
published applications may be obtained from either Private PAIR or Public PAIR. 
Status information for unpublished applications is available through Private PAIR only. 
For more information about the PAIR system, see http://pair-direct.uspto.gov. Should 
you have questions on access to the Private PAIR system, contact the Electronic 
Business Center (EBC) at 866-217-9197 (toll-free). If you would like assistance from a 
USPTO Customer Service Representative or access to the automated information 
system, call 800-786-9199 (IN USA OR CANADA) or 571-272-1000. 
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